<!DOCTYPE html>
<body>
<form>
<input name="radios" type="radio">
<input name="radios" type="radio">
</form>
<script src="../../../resources/js-test.js"></script>
<script>

var nodeListKind = {
    ChildNodeListType: 'document.body.childNodes',
    ClassNodeListType: 'document.getElementsByClassName("class")',
    NameNodeListType: 'document.getElementsByName("name")',
    TagNodeListType: 'document.getElementsByTagName("body")',
    RadioNodeListType: 'document.querySelector("form").elements["radios"]',
    LabelsNodeListType: 'document.querySelector("input").labels',
};

var i = 1;
for (var kind in nodeListKind) {
    var code = nodeListKind[kind];
    // Do initialization work in an inner function to avoid references to
    // objects remaining live on this function's stack frame
    // (http://crbug.com/595672/).
    (() => {eval(code).customProperty = i})();
    gc();
    shouldBe(code + '.customProperty', '' + i++);
}

</script>
</body>
